<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@taglib uri="http://struts.apache.org/tags-html-el" prefix="html-el" %>
<%@taglib uri="http://struts.apache.org/tags-bean-el" prefix="bean-el" %>
<%@taglib uri="http://struts.apache.org/tags-logic-el" prefix="logic-el" %>
<%@taglib uri="/WEB-INF/tld/application.tld" prefix="app" %>

<html-el:form action="/cadastroDoador.do">
	<html-el:hidden property="method" styleId="method"/>
	<table style="width:100%">
		<tr>
			<td align="center" valign="top" width="100%">
				<table style="width:800px">
					<tr>
						<td>
							<table cellpadding="1" cellspacing="4" bgcolor="#FAFAF5" style="width:100%;border:1px gray solid;border-bottom:0px">
								<tr>
									<td><b>Cadastro de Doador</b></td>
								</tr>
							</table>				
							<table cellpadding="1" cellspacing="4" bgcolor="#FAFAF5" style="width:100%;border:1px gray solid">
								<tr>
									<td style="width:100%;padding:10px">
										<table style="width:100%">
											<tr>
												<td style="width:130px" align="left">CNPJ:</td>
												<td align="left"><html-el:text property="cnpjConsultar" styleId="cnpjConsultar" size="17" maxlength="18"/></td>
												<td style="width:10px">&nbsp;</td>
												<td style="width:90px" align="left">Razão Social:</td>
												<td align="left"><html-el:text property="razaoSocialConsultar" styleId="razaoSocialConsultar" size="30" maxlength="50"/></td>
											</tr>
											<tr>
												<td align="left">Ramo de Atividade:</td>
												<td align="left"><app:comboRamoAtividade name="ramoAtividadeConsultar"/></td>
												<td></td>
												<td align="left">UF:</td>
												<td align="left"><app:comboUF name="ufConsultar"/></td>
											</tr>
											<tr>
												<td align="left">Entidade:</td>
												<td align="left"><app:comboEntidade name="entidadeConsultar"/></td>
											</tr>
											<tr>
												<td colspan="5">
													<table width="100%">
														<tr>
															<td height="10"></td>
														</tr>
														<tr>
															<td align="right">
																<html-el:button property="btnConsultar" styleClass="button" value="Consultar" onclick="consultar()"/>
																<html-el:button property="btnIncluir" styleClass="button" value="Incluir" onclick="incluirIniciar()"/>
															</td>
														</tr>
													</table>
												</td>
											</tr>
										</table>
									</td>
								</tr>
								<logic-el:present name="listaResultado" scope="request">
									<tr>
										<td style="height:1px;border-bottom:1px;border-bottom-style:ridge;">&nbsp;</td>
									</tr>
									<tr>
										<td style="padding-left:12px"><b>Total de Registros encontrados:</b> ${contador}</td>
									</tr>
									<tr>
										<td style="width:100%;height:290px;padding:10px;vertical-align:top">
											<div style="width:100%;height:300px;overflow-x:auto;">
												<table cellpadding="0" cellspacing="1" style="width:100%;">
													<tr>
														<th align="center" class="tbResultadoConsultaHeader"></th>
														<th align="center" class="tbResultadoConsultaHeader">CNPJ</th>
														<th align="center" class="tbResultadoConsultaHeader">Razão Social</th>
														<th align="center" class="tbResultadoConsultaHeader">Ramo de Atividade</th>
														<th align="center" class="tbResultadoConsultaHeader">UF</th>
													</tr>
													<logic-el:iterate id="bean" name="listaResultado" scope="request" indexId="i">
														<tr class='tbResultadoConsultaLinha${i%2}'> 
															<td width="25" align="center" class="tbResultadoConsultaInfo"><html-el:radio property="idSelecionado" value="${bean.codigo}" onclick="selectItem(this)"/></td>
															<td width="140" align="left" class="tbResultadoConsultaInfo">${bean.cnpj}</td>
															<td align="left" class="tbResultadoConsultaInfo">${bean.razaoSocial}</td>
															<td width="200" align="center" class="tbResultadoConsultaInfo">${bean.ramoAtividade.descricao}</td>
															<td width="60" align="center" class="tbResultadoConsultaInfo">${bean.localidade.cidade.uf}</td>
														</tr>
													</logic-el:iterate>
													<html-el:hidden property="idSelecionado"/>
												</table>	
											</div>							
										</td>
									</tr>
										<td style="width:100%;padding:10px;vertical-align:top">
											<table style="width:100%">
												<tr>
													<td align="right">
														<logic-el:present name="listaResultado" scope="request">
															<html-el:button property="btnAlterar" styleId="btnAlterar" styleClass="button" value="Alterar" onclick="alterarIniciar()" disabled="true"/>
															<html-el:button property="btnExcluir" styleId="btnExcluir" styleClass="button" value="Excluir" onclick="excluir()" disabled="true"/>
														</logic-el:present>
													</td>
												</tr>
											</table>
										</td>										
								</logic-el:present>
							</table> 
						</td>
					</tr>
				</table>
			</td>
		</tr>
	</table>
	<div id="dialogIncluir" data-dojo-type="dijit.Dialog" title="Doador - Incluir">
		<table>
			<tr>
				<td><b>CNPJ:</b></td>
				<td>
					<input type="text" id="cnpjIncluir" title="CNPJ" size="19" maxlength="18" onblur="verificaCNPJ(this)"/>
				</td>
			</tr>
			<tr>
				<td><b>Razão Social:</b></td>
				<td>
					<input type="text" id="razaoSocialIncluir" title="Razão Social" size="30" maxlength="50"/>
				</td>
			</tr>
			<tr>
				<td><b>Ramo de Atividade:</b></td>
				<td>
					<app:comboRamoAtividade name="ramoAtividadeIncluir"/>
				</td>
			</tr>
			<tr>
				<td><b>Localidade:</b></td>
				<td>
					<app:comboLocalidade name="localidadeIncluir"/>
				</td>
			</tr>
			<tr>
				<td colspan="2" align="right">
					<html-el:button property="btnIncluir" styleClass="button" value="Incluir" onclick="incluir()"/>
				</td>
			</tr>
		</table>
	</div>
	<div id="dialogAlterar" data-dojo-type="dijit.Dialog" title="Doador - Alterar">
		<table>
			<tr>
				<td><b>CNPJ:</b></td>
				<td>
					<input type="text" id="cnpjAlterar" title="CNPJ" size="19" maxlength="18" disabled="disabled"/>
				</td>
			</tr>
			<tr>
				<td><b>Razão Social:</b></td>
				<td>
					<input type="text" id="razaoSocialAlterar" title="Razão Social" size="30" maxlength="50"/>
				</td>
			</tr>
			<tr>
				<td><b>Ramo de Atividade:</b></td>
				<td>
					<app:comboRamoAtividade name="ramoAtividadeAlterar"/>
				</td>
			</tr>
			<tr>
				<td><b>Localidade:</b></td>
				<td>
					<app:comboLocalidade name="localidadeAlterar"/>
				</td>
			</tr>
			<tr>
				<td colspan="2" align="right">
					<html-el:button property="btnAlterar" styleClass="button" value="Alterar" onclick="alterar()"/>
				</td>
			</tr>
		</table>
	</div>
</html-el:form>
<script language="javascript">

	dojo.addOnLoad(function() {
		onFocus("cnpjConsultar");
	});

	jQuery(function($){
	   $("#cnpjIncluir").mask("99.999.999/9999-99");
	   $("#cnpjAlterar").mask("99.999.999/9999-99");
	   $("#cnpjConsultar").mask("99.999.999/9999-99");
	});

	function selectItem(i) {
		document.getElementById("btnAlterar").disabled = false;
		document.getElementById("btnExcluir").disabled = false;
	}
	function consultar() {
		if(document.getElementById("cnpjConsultar").value != "") {
			if(!validateCNPJ('cnpjConsultar'))
				return false;
		}
		document.forms[0].method.value = "consultar";
		document.forms[0].submit();
	}
	function incluirIniciar() {
		document.getElementById('cnpjIncluir').value = "";
		document.getElementById('razaoSocialIncluir').value = "";
		document.getElementById('ramoAtividadeIncluir').value = "";
		document.getElementById('localidadeIncluir').value = "";
		dijit.byId("dialogIncluir").show();
	}
	function incluir() {
		
		if(!mandatoryField('cnpjIncluir')) {
			return false;
		}
		if(!validateCNPJ('cnpjIncluir'))
			return false;
		if(!mandatoryField('razaoSocialIncluir')) {
			return false;
		}
		if(!mandatoryField('ramoAtividadeIncluir')) {
			return false;
		}
		if(!mandatoryField('localidadeIncluir')) {
			return false;
		}
		
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroDoador.do?method=incluir",
		        timeout: 3000,
		        content: {
		        	cnpj:document.getElementById('cnpjIncluir').value,
		        	razaoSocial:document.getElementById('razaoSocialIncluir').value,
		        	ramoAtividade:document.getElementById('ramoAtividadeIncluir').value,
		        	localidade:document.getElementById('localidadeIncluir').value,
		        },
		        load: function(data, ioArgs) {
		        	alert("Doador incluído com sucesso!");
		        },
				error: function(data, ioArgs) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
		
		dijit.byId("dialogIncluir").hide();
	}
	function alterarIniciar() {
		if(!mandatoryRadio('idSelecionado', 'Alteração')) {
			return false;
		}
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroDoador.do?method=alterarIniciar",
		        timeout: 3000,
		        handleAs: "json",
		        content: {idSelecionado:getSelectedRadio('idSelecionado').value},
		        load: function(data) {
		        	document.getElementById('cnpjAlterar').value = data.cnpj;
		        	document.getElementById('razaoSocialAlterar').value = data.razaoSocial;
		        	document.getElementById('ramoAtividadeAlterar').value = data.ramoAtividade.codigo;
		        	document.getElementById('localidadeAlterar').value = data.localidade.codigo;
					dijit.byId("dialogAlterar").show();
		        },
				error: function(data) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
	}
	function alterar() {
		if(!mandatoryField('razaoSocialAlterar')) {
			return false;
		}
		if(!mandatoryField('ramoAtividadeAlterar')) {
			return false;
		}
		if(!mandatoryField('localidadeAlterar')) {
			return false;
		}
		
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroDoador.do?method=alterar",
		        timeout: 3000,
		        content: {
		        	idSelecionado:getSelectedRadio('idSelecionado').value,
		        	cnpj:document.getElementById('cnpjAlterar').value,
		        	razaoSocial:document.getElementById('razaoSocialAlterar').value,
		        	ramoAtividade:document.getElementById('ramoAtividadeAlterar').value,
		        	localidade:document.getElementById('localidadeAlterar').value
		        },
		        load: function(data, ioArgs) {
		        	alert("Doador alterado com sucesso!");
		        	consultar();
		        },
				error: function(data, ioArgs) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
		
		dijit.byId("dialogAlterar").hide();
	}
	function excluir() {
		if(!mandatoryRadio('idSelecionado', 'Exclusão')) {
			return false;
		}
	
		if(!confirm("Deseja realmente excluir?")) {
			return false;
		}	
		
		require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
			xhr.post({
		        url: "cadastroDoador.do?method=excluir",
		        timeout: 3000,
		        content: {idSelecionado:getSelectedRadio('idSelecionado').value},
		        load: function(data, ioArgs) {
		        	alert("Doador excluído com sucesso!");
		        	consultar();
		        },
				error: function(data, ioArgs) {
					showAlertMessage("Erro ao realizar está operação! Tente novamente!");
		        }
		    });
		});
	}
	
	function verificaCNPJ(field) {
		if(field.value != "") {
			require(["dojo/_base/lang", "dojo/_base/xhr"], function(lang, xhr) {
				xhr.post({
			        url: "cadastroDoador.do?method=verificaCNPJ",
			        timeout: 3000,
			        handleAs: "json",
			        content: {cnpj:field.value},
			        load: function(data) {
			        	if(data.razaoSocial) {
			        		alert("Doador já cadastrado para o CNPJ informado!\nRazão Social: " + data.razaoSocial + " - " + data.localidade.cidade.uf);
			        		field.value = "";
			        		field.focus();
			        	}
			        },
					error: function(data) {
						showAlertMessage("Erro ao realizar está operação! Tente novamente!");
			        }
			    });
			});				
		}		
	}
	
</script>
